<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<!DOCTYPE html>
<html lang="zh-CN">
<%@include file="/WEB-INF/common/include-head.jsp" %>
<link rel="stylesheet" href="ztree/zTreeStyle.css">
<script type="text/javascript" src="ztree/jquery.ztree.all-3.5.min.js"></script>
<script type="text/javascript" src="crowd/my-menu.js"></script>
<script>
    $(function () {
    //   生成树形结构
        generateTree();
    //    给添加子节点按钮绑定单击响应函数
        $("#treeDemo").on("click",".addBtn",function () {
            // 将当前节点的 id，作为新节点的 pid 保存到全局变量
            window.pid=this.id;
        //    打开模态框
            $("#menuAddModal").modal("show");
            return false;
        })
    // 给添加子节点中的模态框中的按钮绑定单击函数
        $("#menuSaveBtn").click(function () {
        //    收集表单项中用户输入的数据
            var name=$.trim($("#menuAddModal [name=name]").val());
            var url=$.trim($("#menuAddModal [name=url]").val());
            var icon=$("#menuAddModal [name=icon]:checked").val();
        //    发送ajax请求
            $.ajax({
                url:"menu/save.json",
                type:"post",
                data:{
                    "pid":window.pid,
                    "name":name,
                    "url":url,
                    "icon":icon
                },
                dataType:"json",
                success:function (response) {
                    var result = response.result;
                    if(result=="SUCCESS"){
                        layer.msg("操作成功");
                        // 重新加载树形结构，注意：要在确认服务器端完成保存操作后再刷新
                        // 否则有可能刷新不到最新的数据，因为这里是异步的
                        generateTree();
                    }
                    if(result=="FAILED"){
                        layer.msg("操作失败"+response.message);
                    }
                },
                error:function (response) {
                layer.msg(response.status+""+response.statusText);
                }
            })
                $("#menuAddModal").modal("hide");
            // 清空表单
            // jQuery 对象调用 click()函数，里面不传任何参数，相当于用户点击了一下
            $("#menuResetBtn").click();
        })
    //    给更新按钮绑定单击响应函数
        $("#treeDemo").on("click",".editBtn",function () {
            // 将当前节点的 id，作为新节点的 pid 保存到全局变量
            window.id=this.id;
            //    打开模态框
            $("#menuEditModal").modal("show");
        //   获取ztree的对象
            var zTreeObj = $.fn.zTree.getZTreeObj("treeDemo");
            // 根据 id 属性查询节点对象
            // 用来搜索节点的属性名
            var key="id";
            // 用来搜索节点的属性值 
            var value = window.id;
            var currentNode = zTreeObj.getNodeByParam(key,value);
            // 回显表单数据
            $("#menuEditModal [name=name]").val(currentNode.name);
            $("#menuEditModal [name=url]").val(currentNode.url);
            // 回显 radio 可以这样理解：被选中的 radio 的 value 属性可以组成一个数组，
            //radio回显的本质就是从数组中取出
            // 然后再用这个数组设置回radio，就能够把对应的值选中
            $("#menuEditModal [name=icon]").val([currentNode.icon])
           return false;
        })
        // 给添加子节点中的模态框中的按钮绑定单击函数
        $("#menuEditBtn").click(function () {
            //    收集表单项中用户输入的数据
            var name=$.trim($("#menuEditModal [name=name]").val());
            var url=$.trim($("#menuEditModal [name=url]").val());
            var icon=$("#menuEditModal [name=icon]:checked").val();
            //    发送ajax请求
            $.ajax({
                url:"menu/update.json",
                type:"post",
                data:{
                    "id":window.id,
                    "name":name,
                    "url":url,
                    "icon":icon
                },
                dataType:"json",
                success:function (response) {
                    var result = response.result;
                    if(result=="SUCCESS"){
                        layer.msg("操作成功");
                        // 重新加载树形结构，注意：要在确认服务器端完成保存操作后再刷新
                        // 否则有可能刷新不到最新的数据，因为这里是异步的
                        generateTree();
                    }
                    if(result=="FAILED"){
                        layer.msg("操作失败"+response.message);
                    }
                },
                error:function (response) {
                    layer.msg(response.status+""+response.statusText);
                }
            })
            //关闭模态框
            $("#menuEditModal").modal("hide");
        })
        //    给删除节点按钮绑定单击响应函数
        $("#treeDemo").on("click",".removeBtn",function () {
            // 将当前节点的 id，作为新节点的 pid 保存到全局变量
            window.id=this.id;
            //    打开模态框
            $("#menuConfirmModal").modal("show");
            //   获取ztree的对象
            var zTreeObj = $.fn.zTree.getZTreeObj("treeDemo");
            // 根据 id 属性查询节点对象
            // 用来搜索节点的属性名
            var key="id";
            // 用来搜索节点的属性值
            var value = window.id;
            var currentNode = zTreeObj.getNodeByParam(key,value);
            // 回显表单数据
            $("removeNodeSpan").html("【 <i class='"+currentNode.icon+"'></i>"+currentNode.name+"】")
            return false;
        })
        // 给删除子节点中的模态框中的按钮绑定单击函数
        $("#confirmBtn").click(function () {
            //    发送ajax请求
            $.ajax({
                url:"menu/remove.json",
                type:"post",
                data:{
                    "id":window.id
                },
                dataType:"json",
                success:function (response) {
                    var result = response.result;
                    if(result=="SUCCESS"){
                        layer.msg("操作成功");
                        // 重新加载树形结构，注意：要在确认服务器端完成保存操作后再刷新
                        // 否则有可能刷新不到最新的数据，因为这里是异步的
                        generateTree();
                    }
                    if(result=="FAILED"){
                        layer.msg("操作失败"+response.message);
                    }
                },
                error:function (response) {
                    layer.msg(response.status+""+response.statusText);
                }
            })
            //关闭模态框
            $("#menuConfirmModal").modal("hide");
        })
    })
</script>
<body>

<%@include file="/WEB-INF/common/include-nav.jsp" %>
<div class="container-fluid">
    <div class="row">
        <%@include file="/WEB-INF/common/include-sidebar.jsp" %>
        <div class="col-sm-9 col-sm-offset-3 col-md-10 col-md-offset-2 main">
            <div class="panel panel-default">
                <div class="panel-heading"><i class="glyphicon glyphicon-th-list"></i> 权限菜单列表
                    <div style="float:right;cursor:pointer;" data-toggle="modal" data-target="#myModal"><i
                            class="glyphicon glyphicon-question-sign"></i></div>
                </div>
                <div class="panel-body">
                    <ul id="treeDemo" class="ztree"></ul>
                </div>
            </div>
        </div>
    </div>
</div>
<%@include file="/WEB-INF/common/modal-menu-add.jsp"%>
<%@include file="/WEB-INF/common/modal-menu-confirm.jsp"%>
<%@include file="/WEB-INF/common/modal-menu-edit.jsp"%>
</body>
</html>